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(54) Title: INTERNET ACCESS VIA NON-HOME SERVICE PROVIDERS 
(57) Abstract 



A system capable of granting Internet access to 
users (100) when direct connection to their usual home 
Internet Service Providers (ISPs) is impossible, impractical 
or prohibitively expensive. The system offers users (100) a 
unified method of login to other independent ISPs (102) to 
provide easy and inexpensive access to the Internet and 
its various services. The system validates user logins, 
generates billing data, provides usage time and monitors 
communication links. The system also isolates the shells of 
the servers of the ISPs (102) from the user (100) until such 
time as the user has been determined to be valid, thereby 
providing security to the ISPs (102) against unauthorized 
access to their servers. The system performs these tasks 
while requiring only a small amount of communication 
bandwidth for communication monitoring and billing. 
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INTERNET ACCESS VIA NON-HOME SERVICE PROVIDERS 

BACKGRO^ OF THE INVENTION 
F;tsiq Qf the Ipv^nt^lQff 

An increasingly large number of computer users rely on 
5 accessing the Internet, an international connection of 
computer networks which cooperate to form a seamless 
network for their collective users. The Internet 
offers its users several services, most notably 
electronic mail (email), file transfer protocol (ftp), 
10 access to the World Wide Web (WWW) and the like. 

Related Background Art 

There are several ways to access the Internet, the most 
prevalent of which requires the availability and use of 

15 a telephone link over a modem between the user and the 
user's Internet Service Provider (ISP), such as a SLIP 
or PPP connection over a V.32bis or V.42bis modem. 
SLIP and PPP connections are also appropriate for 
connecting a home computer, or even a small local 

20 network, to a larger local network, which in turn is 
connected to the Internet. 

Several value-added ISPs (VAISP) , such as .the Microsoft 
Network, Compuserve, America -On -Line, and the like, 

25 offer their users local access from a large number of 
cities in various countries. Thus, a user who 
subscribes to one of these VAISPs and is in a foreign 
or non -home city , for example, on business or vacation, 
may be able to connect to the Internet through the 

30 VAISP, without having to subscribe to a local ISP. 

This is not the case, however, for users who have 
accounts with Independent Internet Service Providers 
(IISPs) . In this case, users who travel away from 
35 their home cities and IISPs to other cities must either 
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(1) subscribe to a local ISP at their destination, or 

(2) must access their home ISPs via a long distance 
telephone link. The first option is inconvenient and 
may require expensive service installation, and is 

5 likely to be impractical for short-term visits. The 
second option, although more convenient than the first 
option, can be expensive because of the high phone line 
charges, and the long distance phone connection is 
likely to be unreliable. 

10 

SUMMARY OF THE INVENTION 

The advantages provided by access to the Internet can 
be enhanced considerably if such access is not made 
15 impossible, difficult or expensive during one's 

travels, even if one does not subscribe, or desire to 
subscribe, to the services of a VAISP. 

Therefore it is an object of this invention to provide 
20 user access to the Internet via non-home ISPs without 
the user having to subscribe to a VAISP or a large 
number of ISPs. 

It is another object of this invention to provide a 
25 unified user access method to participating ISPs. 

It is another object of this invention to isolate the 
ISP server shell from the user until such time as the 
server has validated the user. 

30 

It is another object of this invention to provide such 
benefits to the users without the requirement of 
special client software. 
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It is another object of this invention to provide a 
billing and communication monitoring system which is 
practical for both the user and the participating 
independent ISPs , while using a minimum of 
5 communication bandwidth for communication monitoring 
and billing tasks. 

In one aspect of the present invention, there is 
provided a method for connecting a user to the Internet 

10 via a non-home ISP. First, a phone connection is 

established between the user and a server of the non- 
home ISP and then the user sends first login 
information to the server over the phone connection. A 
Remote Access Control (RAC) task is launched by the 

15 server exclusively if the first login information is 
valid. A request for second login information is then 
sent over the phone connection from the server to the 
user by the RAC task, and in response, the user sends 
second login information back to the server. The RAC 

20 task then causes the ISP to send a validation request, 
including the second login information, to a 
Coordinator communicatively connected to the ISP. The 
Coordinator determines whether or not the second login 
data is valid and sends to the ISP a validation 

25 acknowledgement indicating whether the login 

information is valid. If valid, the RAC task grants 
the user access to the Internet via the ISP; otherwise, 
the phone connection between the ISP's server and the 
user is terminated. 

30 

In another aspect of the present invention, a system is 
provided for granting a user access to the Internet. 
The system includes a plurality of ISPs , each ISP being 
capable of a phone connection to the user and having a 
35 server for (1) receiving first login information from 
the user over the phone connection, (2) launching an 
RAC task exclusively if the first login information is 
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valid, (3) sending over the phone connection to the 
user a request by the RAC task for a second login 
information, (4) receiving over the phone connection 
from the user the second login information and (5) 
5 sending a validation request including the second login 
information. This system also includes a Coordinator, 
capable of being communicatively connected to each ISP, 
for (1) receiving the validation request from the 
server sending the validation request, (2) determining 

10 whether the second login information is valid and (3) 
sending to the sending server a validation 
acknowledgement indicating whether the second login 
information is valid. If the validation 
acknowledgement indicates the second login information 

15 is valid, the RAC task of the sending server grants the 
user access to the Internet via the corresponding ISP; 
otherwise, the sending server terminates the phone 
connection to the user, 

20 In the present invention, there is no need for a user 
to subscribe to an inconvenient and expensive local ISP 
at his or her non-home destination. There is also no 
need for the user to access his or her home ISP via a 
long distance telephone link; the phone connection to 

25 the non-home ISP is local, and thus the high expense 
and unreliability of long-distance phone service are 
avoided , 
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The invention itself is set forth in the claims 
appended hereto and forming part of this specification, 
5 while an understanding of embodiments therefor may be 
had by reference to the detailed description taken in 
conjunction with the drawing in which: 

Fig. 1 is a block diagram illustrating the parties 
10 using the invention, the relationship between the 

parties, and the operations carried out in accordance 
with the invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

15 

First Embodiment 

In a first embodiment of the present invention, 
referring to Fig. 1, the parties using the present 
invention may include one of a plurality of Users 100, 
2 0 one of a plurality of Independent Internet Service 

Providers (IISPs) 102, and a Coordinator 104. Various 
operational steps (1) through (10) are also shown, 
whose order of operation and functionality are 
described in detail below. 

25 

System Initialization 

Assuming the Coordinator 104 and the independent ISPs 
10-2 have agreed to work together to provide Internet 
service access to non-home users, the ISPs install 

30 Remote Access Controller (RAC) software on their 

servers. The RAC software can only start operating, 
i.e., launch, upon a user logging in with both a RAC 
login name and a RAC password. The RAC login name and 
password are agreed upon by all of the participating 

35 ISPs 102 and the Coordinator 104, The RAC software is 
installed by ISPs 102 in such manner that its launch 
requires no root privilege. However, the entry of the 
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RAC login name and password cannot launch any other 
task, besides the RAC, in any of the ISPs' servers. 

Each User 100 obtains from Coordinator 104 the RAC 
login name and password and a unique user login name 
and password, together with a list of all participating 
ISPs 102 and their respective access numbers. 
Alternatively, the Coordinator 104 can simply provide 
each of the Users ioo with a login script to perform 
automatically the double login described below. 

Connect ion to the Intsmpi- 

User 100 initiates the connection to the Internet 
sequence by calling over a telephone line through a 
modem a server of one of the independent ISPs 102. At 
the login prompt. User 100 sends over the phone line to 
the server of the non-home ISP the RAC login name and 
password, which corresponds to a special RAC account. 
If the RAC login name and password are valid, i.e., 
match the corresponding RAC login name and password 
stored in the non-home ISP's server, the RAC task, and 
only that task, is launched by the non-home ISP's 
server (Step 1 of Fig. i) . This serves to isolate the 
ISP's server shell from the user until such time as the 
server has validated the user. This provides the ISP 
with greater security against unauthorized access to 
their servers . 

The RAC task then causes to be sent over the phone 
connection to the User 100 a request to login with his 
or her unique user login name and password. User 100 
then logs in with his or. her unique user login name and 
password, and this information is sent over the phone 
connection to the server and the RAC task. As is 
readily apparent, no special client software is 
required to login. An optional login script; a 
standard Winsock . stack (Trumpet, Win95, MacTCP/ 
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interSLIP, Warp, etc.); and the user's normal list of 
clients may be used to simplify user login. 

The RAC task then causes to be sent a Validation 
5 Request to Coordinator 104 with the user's unique login 
name and password (Step 2 of Fig. 1) . The Validation 
Request may be encrypted for security purposes or may 
be unencrypted. The "Coordinator 104 is communicatively 
connected to each participating ISP 102, such as by a 

10 hardwired link, a phone link, a satellite link, or the 
like. The Coordinator 104 determines whether User 
100's unique name and password are valid, i.e., by 
matching both the unique user login name and password 
to one of a plurality of pairs of user login names and 

15 corresponding passwords stored in its user database 
(Step 3 of Fig. 1) . 

If the Coordinator 104 determines that both User 100 's 
login name and password are valid, the Coordinator 104 

20 starts a timer corresponding to the start of User 100 's 
usage of the system (Step 4 of Fig. 1) ; if invalid, no 
timer is started. In either case, the Coordinator 104 
sends a Validation Acknowledgment message, either 
encrypted or in clear, to the RAC task of the server of 

25 the ISP 102 to which User 100 is connected (Step 5 of 
Fig. 1) . 

If the Validation Acknowledgment indicates that User 
100 's login is invalid (User 100 's login name or 

3 0 password or both did not match any of those in the 

database of Coordinator 104), the RAC task causes the 
server to terminate the phone connection with User 100. 
Of course, the RAC task may be programmed to repeat the 
request to the user for the user's unique login name 

3 5 and password for a certain number of additional times, 
for example, two more times, if the user login 
information is invalid the first time, and repeat the 
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validation of the subsequent login information with 
Coordinator 104 for each request, before the user is 
finally disconnected. In addition, the server may 
terminate the phone connection with the user if it does 
5 not receive an expected validation acknowledgment 
within a predetermined period of time. 

If the Validation Acknowledgment indicates, however, 
that User 100' s login is valid, the RAC task causes the 

10 server of the ISP to grant User 100 access to the 
Internet. The server of the ISP 102 starts its own 
timer for User 100 and grants User 100 communication 
access to the Internet, for example through a SLIP or 
PPP emulation (Step 6 of Fig. l). Only now may User 

15 100 be permitted access to the shell of the server of 
ISP 102. 

Billing and Communication Monitoring 

At regular intervals, for example, every 30 seconds, 
20 the RAC task of ISP 102 causes to be sent to the 
Coordinator 104 a Billing Information Packet (BIP) 
(Step 7 of Fig. 1) . The BIP may (1) provide billing 
information, including Internet connection time from 
the ISP timer, to the Coordinator 104, (2) inform the 
25 Coordinator that User 100 is still connected to the 

Internet and (3) confirm the connection status between 
the Coordinator 104 and ISP 102. The Coordinator 104 
acknowledges the receipt of the BIP with a Billing 
Information Acknowledged (BIA) message (Step 8 of Fig. 
30 1) , which also acknowledges that the Coordinator 104 
and ISP 102 are still connected. 

At regular intervals, for example, every 30 seconds, 
the RAC task of ISP 102 also "pings" User 100 by 
35 causing ISP 102 to send to User 100 Connection 

Verification Requests (CVRs) (Step 9 of Fig. 1) . The 
server of ISP 102 then waits for a ping return, or 
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Connection Verification Acknowledgement (CVA) {Step 10 
of Fig. 1). This "pinging" is to verify that User 100 
is still connected to the server. 

5 If either the BIA or the CVA are not received, 

connection between the User 100 and the ISP 102 can be 
terminated. This helps insure that very little 
connection time remains unaccounted for. Further, the 
respective timers in the ISP 102 and the Coordinator 

10 104 also help insure that very little connection time 
remains unaccounted for, since the ISP 102 and the 
Coordinator 104 share billing data as follows. When 
the user disconnects or is disconnected from the 
Internet, the timer in the Coordinator 104 provides the 

15 non-home ISP a first total connection time for the user { 
which is used to generate billing data for the user; 
the timer in the non-home ISP provides a second total 
connection time to generate billing data for the 
Coordinator 104. Moreover, since both the ISP 102 and 

20 the Coordinator 104 share the billing data, invoicing 
between the Coordinator 104 and User 100 is made 
simpler. 

The exchange of BIPs and BIAs between the ISP 102 and 
25 the Coordinator 104, and the exchange of CVRs and CVAs 
between the ISP 102 and the User 100, provide for 
billing and communication monitoring that is practical 
for both the user and the participating ISPs. 
Moreover, since the BIPs, BIAs, CVRs and CVAs use 
30 relatively little information, and are sent on a 

periodic basis, the system requires only a small amount 
of communication bandwidth for communication monitoring 
and billing. 
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Second Embodiment 

In a second embodiment of the present invention, only 
one login is used by User 100 to login to the server of 
independent ISP 102. In this embodiment, User 100 's 
5 login name and password, if valid, would cause the 
server of the ISP 102 to launch only the RAC task. 
Accordingly, the user's login name and password, must 
possess a unique property, or belong to a unique class 
of logins, from which the ISP server can deduce that 
10 only the RAC task, and no other task, is to be 

launched. That same login name and password are then 
sent to the Coordinator 104 for validation as in the 
first embodiment. 

15 Of course, it will be appreciated that the invention 

may take forms other than those specifically described, 
and the scope of the invention is to be determined 
solely by the following claims. 
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WHAT IS CLAIMED IS : 

1. A method for connecting a user to the Internet via 
a non-home Independent Service Provider (ISP) , said 
method comprising the steps of: 

establishing a phone connection between the user 
and a server of the non-home ISP; 

sending over the phone connection first login 
information from the user to the server of the non-home 
ISP; 

launching, by the non-home ISP's server, a Remote 
Access Control (RAC) task exclusively if the first 
login information is valid; 

sending over the phone connection from the server 
to the user a request by the RAC task for second login 
information; ' 

sending over the phone connection from the user to 
the server the second login information so that the RAC 
task causes the non-home ISP to send a validation 
request including the second login information to a 
Coordinator communicatively connected to the non-home 
ISP; 

determining by the Coordinator whether the second 
login data is valid and sending from the Coordinator to 
the non-home ISP a validation acknowledgement 
indicating whether the second login information is 
valid; and 

if the validation acknowledgement received by the 
non-home ISP indicates the second login information is 
valid, granting the user access by the RAC task: to the 
Internet via the non-home ISP, otherwise, terminating 
the phone connection between the non-home ISP's server 
and the user. 

2. A method according to Claim 1, wherein the non- 
home ISP provides the user access to the Internet by 
SLIP emulation. 
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3. A method according to Claim 1, wherein the first 
login information comprises an RAC login name and an 
RAC password. 

4. A method according to Claim 1, wherein the second 
login information comprises a user login name and a 
user password unique to the user. 

5. A method according to Claim 1, wherein the 
validation request is encrypted. 

6. A method according to Claim 4, wherein the 
Coordinator has a database comprising a plurality of 
pairs of user login names and corresponding user 
passwords, and the Coordinator determines whether the 
second login information is valid by matching both the 
unique user login name and unique user password to one 
of the pairs of the plurality of pairs of user login 
names and corresponding user passwords . 

7. A method according to Claim 1, further comprising 
the step of terminating the phone connection by the 
server of the non-home ISP if the non-home ISP does not 
receive the validation acknowledgement within a 
predetermined period of time. 

8. A method according to Claim 1, further comprising 
the steps of starting a first timer in the Coordinator 
for timing the user when said determining step 
determines that the second login information is valid 
and starting a second timer in the non-home ISP for 
timing the user when the user is granted access to the 
Internet by the non-home ISP. 

9. A method according to Claim 8, further comprising 
the steps of: 
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disconnecting the connection between the user and 
the non-home ISP; 

subsequently stopping the first timer in the 
Coordinator to generate a first total connection time 
for the user; and 

stopping the second timer in the non-home ISP to 
generate a second total connection time for the user. 

10. A method according to Claim 9, wherein the first 
total connection time for the user in the Coordinator 
is used to generate billing data for the user and the 
second total connection time for the user in the non- 
home ISP is used to generate billing data for the 
Coordinator, 

11. A method according to Claim 8, further comprising 
the steps of sending a plurality of Billing Information 
Packets (BIP) from the non-home ISP to the Coordinator, 
each BIP being sent at a predetermined interval of 
time, and a plurality of Billing Information 
Acknowledgements (BIA) from the Coordinator to the non- 
home ISP, each BIA being sent in response to receiving 
each BIP. 

12. A method according to Claim 11, wherein the BIP 
comprises a connection time from the second timer of 
the non-home ISP for the user. 

13. A method according to Claim 11, further comprising 
the step of disconnecting the user from the non-home 
ISP if the BIA is not received from the Coordinator in 
response to any of the BIPS, 

14. A method according to Claim 1, further comprising 
the steps of sending a plurality of Connection 
Verification Requests (CVR) from the non-home ISP to 
the user, each CVR being sent at a predetermined 
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interval of time, and sending a plurality of Connecti 
Verification Acknowledgements (CVA) from the user to 
the non-home ISP, each CVA being sent in response to 
receiving each CVR. 



15. A method according to Claim 14, further compris 
the step of disconnecting the user from the non-home 
ISP if the CVA is not received from the user in 
response to any of the CVRs. 

16. A method according to Claim 1, wherein the non- 
home ISP provides the user access to the Internet by 
PPP emulation. 



17. A method according to Claim 1, wherein the user 
uses a login script to send the first and second login 
information to the non-home ISP's server. 

18. A method for connecting a user to the Internet via 
a non-home Independent Service Provider (ISP), said 
method comprising the steps of: 

establishing a phone connection between the user 
and a server of the non-home ISP? 

sending over the phone connection login 
information from the user to the server of the non-home 
ISP; 

launching, by the non-home ISP's server, of a 
Remote Access Controller (RAC) task exclusively if the 
login information is valid, the RAC task causing the 
non-home ISP's server to send a validation request 
including the login information to a Coordinator 
communicatively connected to the non-home ISP; 

determining by the Coordinator whether the login 
data is valid and sending from the Coordinator to the 
non-home ISP a validation acknowledgement indicating 
whether the login information is valid; 
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if the validation acknowledgement received by the 
non-home ISP indicates the login information is valid, 
granting the user access by the RAC task to the 
Internet via the non-home ISP, otherwise, terminating 
the phone connection between the non-home ISP's server 
and the user. 

19. A method according to Claim 18, the login 
information comprises a combined RAC/user login name 
and a combined RAC/user password unique for the user. 

20. A system for providing a user access to the 
Internet , comprising : 

a plurality of Internet Service Providers (ISPs), 
each ISP being capable of a phone connection to the 
user and having a server for (1) receiving first login 
information from the user over the phone connection, 
(2) launching an RAC task exclusively if the first 
login information is valid, (3) sending over the phone 

0 

connection to the user a request by the RAC task for 
second login information, (4) receiving over the phone 
connection from the user the second login information 
and (5) sending a validation request including the 
second login information; and 

a Coordinator, capable of being communicatively 
connected to each ISP, for (1) receiving the validation 
request from the server sending the validation request, 
(2) determining whether the second login information is 
valid and (3) sending to the sending server a 
validation acknowledgement indicating whether the 
second login information is valid, wherein 

if the validation acknowledgement indicates the 
second login information is valid, the RAC task of the 
sending server grants the user access to the Internet 
via the corresponding ISP, and if not valid, the 
sending server terminates the phone connection to the 
user. 
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21. A system for providing a user access to the 
Internet , comprising : 

a plurality of Internet Service Providers (ISPs) 
each ISP being capable of a phone connection to the 
user and having a server for (1) receiving login 
information from the user over the phone connection, 
(2) launching an RAC task exclusively if the login 
information is valid, (3) sending a validation request 
including the login information; and 

a Coordinator, capable of being communicatively 
connected to each ISP, for (1) receiving the validation 
request from the server sending the validation request, 
(2) determining whether the login information is valid 
and (3) sending to the sending server a validation 
acknowledgement indicating whether the login 
information is valid, wherein 

if the validation acknowledgement indicates the 
login information is valid, the RAC task of the sending 
server grants the user access to the Internet via the 
corresponding ISP, and if not valid, the sending server 
terminates the phone connection to the user. 
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